Fixed Points of Type Constructors and Primitive Recursion
نویسندگان
چکیده
For nested or heterogeneous datatypes, terminating recursion schemes considered so far have been instances of iteration, excluding efficient definitions of fixed-point unfolding. Two solutions of this problem are proposed: The first one is a system with equi-recursive nonstrictly positive type constructors of arbitrary finite kinds, where fixedpoint unfolding is computationally invisible due to its treatment on the level of type equality. Positivity is ensured by a polarized kinding system, and strong normalization is proven by a model construction based on saturated sets. The second solution is a formulation of primitive recursion for arbitrary type constructors of any rank. Although without positivity restriction, the second system embeds—even operationally—into the first one.
منابع مشابه
CoInduction in Coq
When providing a collection of constructors to define an inductive type, we actually also define a dual operation: a destructor. This destructor is always defined using the same structure of pattern-matching, so that we have a tendency to forget that we do extend the “pattern-matching” capability with a new destructor at each definition. Constructors and destructors play a dual role in the defi...
متن کاملMonotone ( Co ) Inductive Types and Fixed - Point Types
We study ve extensions of the polymorphically typed lambda-calculus (system F) by type constructs intended to model xed-points of monotone operators. Building on work by H. Geuvers concerning the relation between term rewrite systems for least pre-xed-points and greatest post-xed-points of positive type schemes (i. e., non-nested positive inductive and coinductive types) and so-called retract t...
متن کاملOCamllight in Ott
OCamllight key points •Written in Ott • Faithful to Objective Caml (very nearly) • Type soundness proof mechanized in HOL (Coq and Isabelle/HOL definitions generated too) • Operational semantics validated on test programs • Small-step operational semantics (131 rules) • Type system (179 rules, below) • definitions: – variant data types (e.g., type t = I of int | C of char), – record types (e.g....
متن کاملAn upper bound for the proof theoretical strength of Martin-Löf Type Theory with W-type and one universe
Definition 1.1 (a) The symbols of Martin-Löf ’s type theory are infinitely many variables zi (i ∈ ω); the symbols ⇒, :, ,, (, ), =, ∈, λ; the term constructors (with their arity in parenthesis) 0 (0), r (0), n (0), nk (for each n < k, with arity 0), nk (for each k ∈ ω, with arity 0), S (1), i (1), j (1), p0 (1), p1 (1), p (2), sup (2), R (2), Ap (2), +̃ (2), π (2), σ (2), w (2), D (3), P (3), ĩ ...
متن کاملTowards a Convenient Category of Topological Domains
We propose a category of topological spaces that promises to be convenient for the purposes of domain theory as a mathematical theory for modelling computation. Our notion of convenience presupposes the usual properties of domain theory, e.g. modelling the basic type constructors, fixed points, recursive types, etc. In addition, we seek to model parametric polymorphism, and also to provide a fl...
متن کامل